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j Listing of Claims: 

1 . (Original) A distributed multiprocessing computer system, comprising: 

a plurality of processor nodes each coupled to an associated memory 
module, wherein each memory module may store data that is shared between 
said processor nodes; 

a Home processor node that includes a data block and a coherence 
directory for said data block in an associated memory module; 

an Owner processor node that includes a copy of said data block in a 
memory module associated with the Owner processor node, said copy of said 
data block residing exclusively in said memory module; 

a Requestor processor node that encounters a read or write miss of said 
data block and requests said data block from the Home processor node; and 

wherein said Home processor node receives the request for the data block 
from the Requestor processor node, forwards the request to the Owner processor 
node for the data block and performs a speculative write of the next directory 
state to the coherence directory for the data block without waiting for the Owner 
processor node to respond to the request. 

2. (Original) The distributed multiprocessing computer system of claim 1, 
wherein the speculative write of the next directory state occurs only if the next 
directory state cannot be determined and the Home processor node and Owner 
processor node are two different processor chips in the computer system, 

3. (Original) The distributed multiprocessing computer system of claim 1, 
wherein the memory module containing the coherence directory for the data block 
is in a low latency state that reduces memory read and write access times while 
the Home processor node is performing the speculative write of the next directory 
state to the coherence directory for the data block. 

4. (Original) The distributed multiprocessing computer system of claim t ( 
further comprising correcting the next directory state for the data block if the 
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response by the Owner processor node to the Home processor node request for 
the data block indicates a different next directory state from the next directory 
state speculatively written by the Home processor node to the coherence 
directory for the data block. 

5. (Original) A distributed multiprocessing computer system, comprising; 

a plurality of processor -nodes each coupled to an associated memory 
module, wherein each memory module may store data that is shared between 
said processor nodes; 

a first processor node that includes a data block and a coherence directory 
for said data block in an associated memory module; 

a second processor node that includes a copy of said data block in a 
memory module associated with the second processor node t said copy of said 
data block residing exclusively in said memory module; 

a third processor node that encounters a read or write miss of said data 
block and requests said data block from the first processor node; and 

wherein said first processor node receives the request for the data block 
from the third processor node, forwards the request to the second processor node 
for the data block and performs a speculative write of the next directory state to 
the coherence directory for the data block without waiting for the second 
processor node to respond to the request, said next directory state selected to 
reduce read-modify-write sequences. 

6. (Original) The distributed multiprocessing computer system of claim 5, 
wherein the speculative write of the next directory state occurs only if the next 
directory state cannot be determined and the first processor node and second 
processor node are two different processor chips in the computer system. 

7. (Original) The distributed multiprocessing computer system of claim 5, 
wherein the memory module containing the coherence directory for the data block 
is in a low latency state that reduces memory read and write access times while 

1 24477.01/1 662.27800 Page 3 Of 9 HP PDNO 200301788-1 



PAGE 6/12* RCVD AT 6/4/2004 5:31 :58 PM [Eastern Daylight Time] * SVR:USPT0-EFXRM/2 * DNIS:8729306 * CSID:713 238 8008 * DURATION (mm-ss):04-06 



Sent by: CONLEY ROSE, P.C- 



713 238 8008; 



06/04/04 15:23; JfitQa_#203 ; Page 7/12 



Appl.No.: 09/652,834 

Amrft dated June 4, 2004 

Reply to Office action of March 31 , 2004 

the first processor node is performing the speculative write of the next directory 
state to the coherence directory for the data block. 

8. (Original) The distributed multiprocessing computer system of claim 5, 
further comprising correcting the next directory state for the data block if the 
response by the second processor node to the first processor node request for 
the data block indicates a different next directory state from the next directory 
state speculatively written by the first processor node to the coherence directory 
for the data block. 

9. (Original) The distributed multiprocessing computer system of claim 5, 
wherein the speculative write of the next directory state releases hardware 
contained in the first processor node, allowing said first processor node to accept 
requests for data blocks and coherency directories for said data blocks stored in 
the memory module of the first processor node. 

10. (Original) A distributed multiprocessing computer system, comprising: 

a plurality of processor nodes each coupled to an associated memory 
module, wherein each memory module may store data that is shared between 
said processor nodes; 

a Home processor node that includes a data block and a coherence 
directory for said data Mock in an associated memory module; 

an Owner processor node that includes a copy of said data block in a 
memory module associated with the Owner processor node, said copy of said 
data block residing exclusively in said memory module; 

a Requestor processor node that encounters a read or write miss of said 
data block and requests said data block from the Home processor node; 

wherein said Home processor node receives the request for the data block 
from the Requestor processor node, forwards the request to the Owner processor 
node for the data block and performs a speculative write of the next directory 
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state to the coherence directory for the data block without waiting for the Owner 
processor node to respond to the request; and 

a disk drive coupled to each of said plurality of processor nodes. 

11. (Previously presented) A method, comprising: 
receiving a request for a data block; 

forwarding the request to an owner node at which an updateable directory 

state of the data block is stored; and 
speculatively writing the directory state before receiving a coherence 

response from the owner. 

12. (Previously presented) The method of claim 11 further comprising re- 
writing the directory state upon receipt of a coherency response from the owner. 

13. (Previously presented) The method of claim 11 further comprising 
confirming the speculatively written directory state upon receipt of a coherency 
response from the owner. 

14. (Previously presented) An apparatus adapted to communicate with an 
owner node that is configured to have an exclusive copy of a data block, the 
apparatus comprising: 

memory in which a directory table is stored, the directory table including an 
configurable cache state associated with the data block; and 

a cache controller that speculatively updates the data block's cache state 
in the directory table upon receiving a memory request and before 
the apparatus receives a coherence response from the owner node. 

15. (Previously presented) The apparatus of claim 14 wherein, upon receiving 
the coherence response from the owner node, the cache controller confirms the 
speculatively updated cache state if the updated cache state comports with the 
cache information provided in the coherence response. 
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16. (Previously presented) The apparatus of claim 14 wherein, upon receiving 
the coherence response from the owner node, the cache controller changes the 
speculatively updated cache state if the updated cache state does not comport 
with the cache information provided in the coherence response. 
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